<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="script/vue-2.4.0.js"></script>
</head>

<body>
    <div id="app">
        <h1>多余的字符省略</h1>
        <ul>
            <li v-for="(item,index) in titles" :key="index" v-substr="10">{{item}}</li>
        </ul>
    </div>
    <script>
        //自定义：字符个数的省略显示指令
        Vue.directive('substr', {
            //生命周期
            inserted: function(el, bind) {
                //获得指令传递的参数 bind.value
                //el:el就是使用自定义指令的标记，案例中就是上面li标记，获得li标记，获得里面的文字内容
                //outerText获得一对标记包含的文本内容
                let str = el.outerText
                if (str.length > bind.value) {
                    //substring(参数一，参数2) 参数1代表从哪里开始截取，参数2截取多少个
                    el.innerText = str.substring(0, bind.value) + '...'
                }


            }
        })
        Vue.config.productionTip = false //关闭生成信息提示
        var vm = new Vue({
            el: '#app',
            data: {
                titles: [
                    '晚风中闪过几帧从前啊,爱几帧的几帧wa',
                    'Vue实战开发,从入门到放弃',
                    '封城多少天才解封',
                    '最新的火车票抢票软件，点击下载',
                ]
            },
            methods: {},
            filters: {},
            directives: {}
        })
    </script>
</body>

</html>